Lightning Web Components (LWC) এবং Apex দুটি গুরুত্বপূর্ণ প্রযুক্তি Salesforce প্ল্যাটফর্মের মধ্যে, এবং এগুলির সমন্বয় দ্বারা শক্তিশালী, স্কেলযোগ্য এবং ইন্টারঅ্যাকটিভ অ্যাপ্লিকেশন তৈরি করা সম্ভব হয়। LWC হলো Salesforce এর ফ্রন্টএন্ড ফ্রেমওয়ার্ক, যা ওয়েব স্ট্যান্ডার্ড ব্যবহার করে দ্রুত এবং সুরক্ষিত ইউজার ইন্টারফেস তৈরি করতে সহায়ক, আর Apex হলো Salesforce-এর প্রোগ্রামিং ভাষা, যা ডেটাবেস এবং ব্যাকএন্ড লজিকের জন্য ব্যবহৃত হয়।
LWC এবং Apex-এর মধ্যে সমন্বয় ডেভেলপারদের জন্য অত্যন্ত গুরুত্বপূর্ণ, কারণ এটি তাদেরকে ক্লায়েন্ট-সাইড এবং সার্ভার-সাইড কোডের মধ্যে তথ্য এবং কার্যকলাপের ইন্টিগ্রেশন করতে দেয়।
Apex এর মাধ্যমে LWC-তে ডেটা প্রেরণ
LWC এর মাধ্যমে ব্যবহারকারীর ইন্টারঅ্যাকশন বা ডেটা ভিউয়ার প্রক্রিয়ার জন্য কাস্টম Apex ক্লাস ব্যবহার করা হয়। Apex ব্যাকএন্ড লজিক এবং ডেটা প্রসেসিং এর জন্য কাজ করে, এবং LWC ওই ডেটাকে সুন্দরভাবে এবং ইন্টারঅ্যাকটিভভাবে ইউজারের সামনে উপস্থাপন করে।
LWC তে Apex ডেটা রিট্রিভ করার জন্য @wire
ডেকোরেটর ব্যবহার করা হয়।
উদাহরণ:
import { LightningElement, wire } from 'lwc';
import getAccounts from '@salesforce/apex/AccountController.getAccounts';
export default class AccountList extends LightningElement {
@wire(getAccounts) accounts;
}
এই কোডে @wire
ডেকোরেটর Apex ক্লাসের getAccounts
মেথডকে কল করে এবং সেই ডেটা accounts
প্রপার্টিতে গ্রহণ করে।
Apex ক্লাস তৈরি এবং LWC এর সাথে সংযুক্ত করা
Apex কোডে ক্লাস তৈরি করতে এবং সেই ক্লাসটি LWC এর সাথে যুক্ত করতে, আপনাকে সেই Apex ক্লাসে @AuraEnabled
অ্যানোটেশন ব্যবহার করতে হবে, যা ক্লাসটি Lightning Web Components থেকে এক্সেসযোগ্য করে।
Apex ক্লাস উদাহরণ:
public with sharing class AccountController {
@AuraEnabled(cacheable=true)
public static List<Account> getAccounts() {
return [SELECT Id, Name FROM Account LIMIT 10];
}
}
এই ক্লাসটি Salesforce থেকে অ্যাকাউন্টের ডেটা রিট্রিভ করবে এবং সেই ডেটা LWC এর মাধ্যমে ফ্রন্টএন্ডে প্রদর্শিত হবে।
LWC থেকে Apex মেথড কল করা (Imperative Approach)
কখনও কখনও আপনি @wire
এর পরিবর্তে imperative
পদ্ধতি ব্যবহার করতে চাইবেন, যেখানে কোডের মধ্যে সরাসরি Apex মেথড কল করতে হয়।
LWC (Imperative Method) উদাহরণ:
import { LightningElement } from 'lwc';
import getAccounts from '@salesforce/apex/AccountController.getAccounts';
export default class AccountList extends LightningElement {
accounts;
handleGetAccounts() {
getAccounts()
.then(result => {
this.accounts = result;
})
.catch(error => {
console.error('Error retrieving accounts:', error);
});
}
}
এখানে getAccounts
Apex মেথডটি imperatively কল করা হয়েছে, এবং ডেটা accounts
প্রপার্টিতে সংরক্ষণ করা হয়েছে।
LWC থেকে Apex মেথডে প্যারামিটার পাঠানো
LWC থেকে Apex মেথডে প্যারামিটার পাঠানোর জন্য, Apex মেথডে প্যারামিটার গ্রহণের জন্য সাধারণ প্যারামিটার ব্যবহার করা হয়।
Apex মেথড উদাহরণ:
public with sharing class AccountController {
@AuraEnabled
public static List<Account> getAccountsByIndustry(String industry) {
return [SELECT Id, Name FROM Account WHERE Industry = :industry LIMIT 10];
}
}
LWC তে প্যারামিটার পাঠানোর উদাহরণ:
import { LightningElement } from 'lwc';
import getAccountsByIndustry from '@salesforce/apex/AccountController.getAccountsByIndustry';
export default class AccountList extends LightningElement {
industry = 'Technology';
accounts;
handleGetAccounts() {
getAccountsByIndustry({ industry: this.industry })
.then(result => {
this.accounts = result;
})
.catch(error => {
console.error('Error retrieving accounts:', error);
});
}
}
এখানে industry
প্যারামিটারটি LWC থেকে Apex মেথডে পাঠানো হয়েছে, এবং Apex সেই প্যারামিটারটি ব্যবহার করে ডেটা রিট্রিভ করবে।
Error Handling
LWC এবং Apex এর মধ্যে যোগাযোগ করার সময় error handling অত্যন্ত গুরুত্বপূর্ণ। যদি Apex মেথডটি কোনো ত্রুটি তৈরি করে, তাহলে সঠিকভাবে ত্রুটি ধরা এবং ব্যবহারকারীর কাছে উপস্থাপন করা দরকার।
Apex তে Error Handling উদাহরণ:
public with sharing class AccountController {
@AuraEnabled
public static List<Account> getAccountsByIndustry(String industry) {
try {
return [SELECT Id, Name FROM Account WHERE Industry = :industry LIMIT 10];
} catch (Exception e) {
throw new AuraHandledException('Error retrieving accounts: ' + e.getMessage());
}
}
}
LWC Error Handling উদাহরণ:
import { LightningElement } from 'lwc';
import getAccountsByIndustry from '@salesforce/apex/AccountController.getAccountsByIndustry';
export default class AccountList extends LightningElement {
accounts;
error;
handleGetAccounts() {
getAccountsByIndustry({ industry: 'Technology' })
.then(result => {
this.accounts = result;
})
.catch(error => {
this.error = 'Error retrieving accounts: ' + error.body.message;
});
}
}
এখানে, যদি কোনো ত্রুটি হয়, তাহলে সেটি LWC কম্পোনেন্টে error
প্রপার্টির মাধ্যমে ব্যবহারকারীকে প্রদর্শিত হবে।
@wire
এবং imperative
পদ্ধতির মাধ্যমে দ্রুত ডেটা ফেচিং এবং ডিসপ্লে।Lightning Web Components (LWC) এবং Apex Salesforce প্ল্যাটফর্মের দুটি শক্তিশালী প্রযুক্তি, যা একে অপরকে শক্তিশালী করে। Apex কোড ব্যাকএন্ড লজিক এবং ডেটা প্রসেসিং প্রদান করে, এবং LWC ফ্রন্টএন্ডে ইন্টারঅ্যাকটিভ ইউজার ইন্টারফেস তৈরি করে। তাদের সঠিক সমন্বয় একটি দক্ষ এবং স্কেলেবল অ্যাপ্লিকেশন তৈরির জন্য অপরিহার্য। LWC এবং Apex এর মধ্যকার ইন্টিগ্রেশন, যেমন @wire
, imperative
কল, প্যারামিটার পাঠানো এবং ত্রুটি পরিচালনা, ডেভেলপারদের জন্য একটি শক্তিশালী টুল তৈরি করে যা সহজেই ডেটা এক্সচেঞ্জ এবং অ্যাপ্লিকেশন ব্যবস্থাপনা করতে সক্ষম।
common.read_more